1
|
|
|
var program = require('commander'); |
2
|
|
|
var shell = require('shelljs'); |
3
|
|
|
var chalk = require('chalk'); |
4
|
|
|
var co = require('co'); |
5
|
|
|
var prompt = require('co-prompt'); |
6
|
|
|
var fs = require('fs'); |
7
|
|
|
|
8
|
|
|
program |
9
|
|
|
// .usage('') |
10
|
|
|
.action(function() { |
11
|
|
|
|
12
|
|
|
var enviroment = process.env.npm_package_config_enviroment; |
13
|
|
|
|
14
|
|
|
shell.echo('Compile Workspace ('+enviroment+')'); |
15
|
|
|
|
16
|
|
|
shell.cd('applications/workspace/'); |
17
|
|
|
|
18
|
|
|
fs.readFile('config.php.dist', 'utf8', function (err,data) { |
19
|
|
|
|
20
|
|
|
if (err) { |
21
|
|
|
process.stderr.write(chalk.red("Errore in lettura: "+err)); |
22
|
|
|
process.exit(1); |
|
|
|
|
23
|
|
|
} |
24
|
|
|
|
25
|
|
|
var result; |
26
|
|
|
if ( enviroment === 'dev' ){ |
27
|
|
|
result = data.replace(/##TYPE##/g, 'sqlite'); |
28
|
|
|
result = result.replace(/##HOST##/g, 'ROOT_PATH.\'/../database/workspace.sqlite\''); |
29
|
|
|
result = result.replace(/##DBNAME##/g, ''); |
30
|
|
|
result = result.replace(/##PASSWORD##/g, ''); |
31
|
|
|
result = result.replace(/##USERNAME##/g, ''); |
32
|
|
|
result = result.replace(/##LOGLEVEL##/g, '\\Monolog\\Logger::DEBUG'); |
33
|
|
|
} else if ( enviroment === 'vagrant' ){ |
34
|
|
|
result = data.replace(/##TYPE##/g, 'mysql'); |
35
|
|
|
result = result.replace(/##HOST##/g, '\'localhost\''); |
36
|
|
|
result = result.replace(/##DBNAME##/g, 'workspace'); |
37
|
|
|
result = result.replace(/##PASSWORD##/g, 'workspace'); |
38
|
|
|
result = result.replace(/##USERNAME##/g, 'workspace'); |
39
|
|
|
result = result.replace(/##LOGLEVEL##/g, '\\Monolog\\Logger::DEBUG'); |
40
|
|
|
} else { |
41
|
|
|
// STAGING / PROD |
42
|
|
|
result = data.replace(/##TYPE##/g, 'mysql'); |
43
|
|
|
if ( |
44
|
|
|
!process.env.npm_package_config_database_host || |
45
|
|
|
!process.env.npm_package_config_database_host || |
46
|
|
|
!process.env.npm_package_config_database_dbname || |
47
|
|
|
!process.env.npm_package_config_database_password || |
48
|
|
|
!process.env.npm_package_config_database_username |
49
|
|
|
) { |
50
|
|
|
process.stderr.write(chalk.red("Errore manca la configurazione in .npmrc")); |
51
|
|
|
process.exit(1); |
|
|
|
|
52
|
|
|
} |
53
|
|
|
result = result.replace(/##HOST##/g, '\''+process.env.npm_package_config_database_host+'\''); |
54
|
|
|
result = result.replace(/##DBNAME##/g, process.env.npm_package_config_database_dbname); |
55
|
|
|
result = result.replace(/##PASSWORD##/g, process.env.npm_package_config_database_password); |
56
|
|
|
result = result.replace(/##USERNAME##/g, process.env.npm_package_config_database_username); |
57
|
|
|
result = result.replace(/##LOGLEVEL##/g, '\\Monolog\\Logger::INFO'); |
58
|
|
|
} |
59
|
|
|
|
60
|
|
|
|
61
|
|
|
fs.writeFile('config.php', result, 'utf8', function (err) { |
62
|
|
|
if (err) { |
63
|
|
|
process.stderr.write(chalk.red("Errore in scrittura: "+err)); |
64
|
|
|
process.exit(1); |
|
|
|
|
65
|
|
|
} |
66
|
|
|
}); |
67
|
|
|
}); |
68
|
|
|
|
69
|
|
|
}) |
70
|
|
|
.parse(process.argv); |
71
|
|
|
|
72
|
|
|
|
73
|
|
|
// if (!process.argv.slice(2).length) { |
74
|
|
|
// program.outputHelp(make_red); |
75
|
|
|
// } |
76
|
|
|
// |
77
|
|
|
// function make_red(txt) { |
78
|
|
|
// return chalk.red(txt); |
79
|
|
|
// } |
80
|
|
|
|